SqlServer数据库DROP TABLE IF EXISTS语句 | 您所在的位置:网站首页 › sql drop删除表 › SqlServer数据库DROP TABLE IF EXISTS语句 |
近日碰到SqlServer数据库版本不一致,执行建表脚本时DROP TABLE IF EXISTS语法的小问题,自己做个记录便于后续查看。 在SqlServer2016版本及更高版本,建表前判断表是否存在,可以使用: DROP TABLE IF EXISTS myschema.mytable; CREATE TABLE myschema.mytable( STUNAM varchar(20) not null default '', CRTTIM datetime DEFAULT CURRENT_TIMESTAMP, UPDTIM datetime DEFAULT CURRENT_TIMESTAMP , PRIMARY KEY (STUNAM) ); EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'demo表', @level0type=N'SCHEMA', @level0name=N'myschema', @level1type=N'TABLE', @level1name=N'mytable'; -- 添加表注释 -- 添加字段注释 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'学生姓名', @level0type=N'SCHEMA', @level0name=N'myschema', @level1type=N'TABLE', @level1name=N'mytable', @level2type=N'column', @level2name=N'STUNAM';但是在 低版本的SqlServer并不支持, DROP TABLE IF EXISTS 的语法,可替换成: IF OBJECT_ID(N'myschema.mytable', N'U') IS NOT NULL DROP TABLE myschema.mytable;在低版本执行 DROP TABLE IF EXISTS 会报错 在应使用条件的上下文中指定了非布尔类型的表达式
|
CopyRight 2018-2019 实验室设备网 版权所有 |